export const setting = {
  // 动态锚点、位置自适应
  Anchors: ['Top', 'TopCenter', 'TopRight', 'TopLeft', 'Right', 'RightMiddle', 'Bottom', 'BottomCenter',
    'BottomRight', 'BottomLeft', 'Left', 'LeftMiddle'
  ],
  // 容器ID
  Container: 'efContainer',
  // 连线的样式，直线或者曲线等，可选值:  StateMachine、Flowchart，Bezier、Straight
  Connector: ['Bezier', {curviness: 100}],
  // Connector: ['Straight', {stub: 20, gap: 1}],
  // Connector: ['Flowchart', {stub: 30, gap: 1, alwaysRespectStubs: false, midpoint: 0.5, cornerRadius: 10}],
  // Connector: ['StateMachine', {margin: 5, curviness: 10, proximityLimit: 80}],
  // 鼠标不能拖动删除线
  ConnectionsDetachable: false,
  // 删除线的时候节点不删除
  DeleteEndpointsOnDetach: false,
  /**
   * 连线的两端端点类型：圆形
   * radius: 圆的半径，越大圆越大
   */
  // Endpoint: ['Dot', {radius: 5, cssClass: 'ef-dot', hoverClass: 'ef-dot-hover'}],
  /**
   * 连线的两端端点类型：矩形
   * height: 矩形的高
   * width: 矩形的宽
   */
  // Endpoint: ['Rectangle', {height: 20, width: 20, cssClass: 'ef-rectangle', hoverClass: 'ef-rectangle-hover'}],
  /**
   * 图像端点
   */
  // Endpoint: ['Image', {src: 'https://www.easyicon.net/api/resizeApi.php?id=1181776&size=32', cssClass: 'ef-img', hoverClass: 'ef-img-hover'}],
  /**
   * 空白端点
   */
  Endpoint: ['Blank', {
    Overlays: ''
  }],
  // Endpoints: [['Dot', {radius: 5, cssClass: 'ef-dot', hoverClass: 'ef-dot-hover'}], ['Rectangle', {height: 20, width: 20, cssClass: 'ef-rectangle', hoverClass: 'ef-rectangle-hover'}]],
  /**
   * 连线的两端端点样式
   * fill: 颜色值，如：#12aabb，为空不显示
   * outlineWidth: 外边线宽度
   */
  EndpointStyle: {
    fill: '#1879ffa1',
    outlineWidth: 1
  },
  // 是否打开jsPlumb的内部日志记录
  LogEnabled: true,
  /**
   * 连线的样式
   */
  PaintStyle: {
    // 线的颜色
    stroke: '#E0E3E7',
    // 线的粗细，值越大线越粗
    strokeWidth: 1,
    // 设置外边线的颜色，默认设置透明，这样别人就看不见了，点击线的时候可以不用精确点击，参考 https://blog.csdn.net/roymno2/article/details/72717101
    outlineStroke: 'transparent',
    // 线外边的宽，值越大，线的点击范围越大
    outlineWidth: 10
  },
  DragOptions: {
    cursor: 'pointer',
    zIndex: 2000
  },
  /**
   *  叠加 参考： https://www.jianshu.com/p/d9e9918fd928
   */
  Overlays: [
    // 箭头叠加
    ['Arrow', {
      width: 10, // 箭头尾部的宽度
      length: 8, // 从箭头的尾部到头部的距离
      location: 1, // 位置，建议使用0～1之间
      direction: 1, // 方向，默认值为1（表示向前），可选-1（表示向后）
      foldback: 0.623 // 折回，也就是尾翼的角度，默认0.623，当为1时，为正三角
    }],
    // ['Diamond', {
    //   events: {
    //     dblclick: function(diamondOverlay, originalEvent) {
    //       console.log('double click on diamond overlay for : ' + diamondOverlay.component)
    //     }
    //   }
    // }],
    ['Label', {
      label: '',
      location: 0.1,
      cssClass: 'aLabel'
    }]
  ],
  // 绘制图的模式 svg、canvas
  RenderMode: 'svg',
  // 鼠标滑过线的样式
  HoverPaintStyle: {
    stroke: '#b0b2b5',
    strokeWidth: 1
  },
  // 滑过锚点效果
  // EndpointHoverStyle: {fill: 'red'},
  Scope: 'jsPlumb_DefaultScope' // 范围，具有相同scope的点才可连接
}

/**
 * 连线参数
 */
export const connectOptions = {
  isSource: true,
  isTarget: true,
  // 动态锚点、提供了4个方向 Continuous、AutoDefault
  anchor: 'Continuous',
  // 设置连线上面的label样式
  labelStyle: {
    cssClass: 'flowLabel'
  },
  // 修改了jsplumb 源码，支持label 为空传入自定义style
  emptyLabelStyle: {
    cssClass: 'emptyFlowLabel'
  }
}

/**
 * 源点配置参数
 */
// 参考 https://www.cnblogs.com/mq0036/p/7942139.html
export const sourceOptions = {
  // 设置可以拖拽的类名，只要鼠标移动到该类名上的DOM，就可以拖拽连线
  filter: '.node-box-left',
  filterExclude: false,
  anchor: 'Continuous',
  allowLoopback: false,//can to self?
  maxConnections: -1,
  onMaxConnections: function(info, e) {
    console.log(`超过了最大值连线: ${info.maxConnections}`)
  }
}

export const targetOptions = {
  filter: '.node-box-left',
  filterExclude: false,
  anchor: 'Continuous',
  allowLoopback: false,
  dropOptions: {
    hoverClass: 'ef-drop-hover'
  }
}
